/********************************************************************* * * Copyright (C) 2002 Andrew Khan * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ***************************************************************************/ package jxl.write.biff; import jxl.common.Assert; import jxl.biff.Fonts; import jxl.biff.FormattingRecords; import jxl.biff.NumFormatRecordsException; import jxl.write.NumberFormats; import jxl.write.WritableCellFormat; /** * Handles the Format and XF record indexing. The writable subclass * instantiates the predetermined list of XF records and formats * present in every Excel Workbook */ public class WritableFormattingRecords extends FormattingRecords { /** * The statically defined normal style */ public static WritableCellFormat normalStyle; /** * Constructor. Instantiates the prerequisite list of formats and * styles required by all Excel workbooks * * @param f the list of Fonts * @param styles the list of style clones */ public WritableFormattingRecords(Fonts f, Styles styles) { super(f); try { // Hard code all the styles StyleXFRecord sxf = new StyleXFRecord (styles.getArial10Pt(),NumberFormats.DEFAULT); sxf.setLocked(true); addStyle(sxf); sxf = new StyleXFRecord(getFonts().getFont(1),NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); sxf = new StyleXFRecord(getFonts().getFont(1),NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); sxf = new StyleXFRecord(getFonts().getFont(1),NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); sxf = new StyleXFRecord(getFonts().getFont(2),NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); sxf = new StyleXFRecord(getFonts().getFont(3),NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); sxf = new StyleXFRecord(styles.getArial10Pt(), NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); sxf = new StyleXFRecord(styles.getArial10Pt(), NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); sxf = new StyleXFRecord(styles.getArial10Pt(), NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); sxf = new StyleXFRecord(styles.getArial10Pt(), NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); sxf = new StyleXFRecord(styles.getArial10Pt(), NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); sxf = new StyleXFRecord(styles.getArial10Pt(), NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); sxf = new StyleXFRecord(styles.getArial10Pt(), NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); sxf = new StyleXFRecord(styles.getArial10Pt(), NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); sxf = new StyleXFRecord(styles.getArial10Pt(), NumberFormats.DEFAULT); sxf.setLocked(true); sxf.setCellOptions(0xf400); addStyle(sxf); // That's the end of the built ins. Write the normal style // cell XF here addStyle(styles.getNormalStyle()); // Continue with "user defined" styles sxf = new StyleXFRecord(getFonts().getFont(1), NumberFormats.FORMAT7); sxf.setLocked(true); sxf.setCellOptions(0xf800); addStyle(sxf); sxf = new StyleXFRecord(getFonts().getFont(1), NumberFormats.FORMAT5); sxf.setLocked(true); sxf.setCellOptions(0xf800); addStyle(sxf); sxf = new StyleXFRecord(getFonts().getFont(1), NumberFormats.FORMAT8); sxf.setLocked(true); sxf.setCellOptions(0xf800); addStyle(sxf); sxf = new StyleXFRecord(getFonts().getFont(1), NumberFormats.FORMAT6); sxf.setLocked(true); sxf.setCellOptions(0xf800); addStyle(sxf); sxf = new StyleXFRecord(getFonts().getFont(1), NumberFormats.PERCENT_INTEGER); sxf.setLocked(true); sxf.setCellOptions(0xf800); addStyle(sxf); // Hard code in the pre-defined number formats for now /* FormatRecord fr = new FormatRecord ("\"$\"#,##0_);\\(\"$\"#,##0\\)",5); addFormat(fr); fr = new FormatRecord ("\"$\"#,##0_);[Red]\\(\"$\"#,##0\\)", 6); addFormat(fr); fr = new FormatRecord ("\"$\"#,##0.00_);\\(\"$\"#,##0.00\\)", 7); addFormat(fr); fr = new FormatRecord ("\"$\"#,##0.00_);[Red]\\(\"$\"#,##0.00\\)", 8); addFormat(fr); fr = new FormatRecord ("_(\"$\"* #,##0_);_(\"$\"* \\(#,##0\\);_(\"$\"* \"-\"_);_(@_)", 0x2a); // outputFile.write(fr); fr = new FormatRecord ("_(* #,##0_);_(* \\(#,##0\\);_(* \"-\"_);_(@_)", 0x2e); // outputFile.write(fr); fr = new FormatRecord ("_(\"$\"* #,##0.00_);_(\"$\"* \\(#,##0.00\\);_(\"$\"* \"-\"??_);_(@_)", 0x2c); // outputFile.write(fr); fr = new FormatRecord ("_(* #,##0.00_);_(* \\(#,##0.00\\);_(* \"-\"??_);_(@_)", 0x2b); // outputFile.write(fr); */ } catch (NumFormatRecordsException e) { // This should not happen yet, since we are just creating the file. // Bomb out Assert.verify(false, e.getMessage()); } } }